12605
23382
Selenium 테스트를 개발하고 실행하기 위해 Jetty, OpenEJB 및 WebApps가있는 환경을 프로그래밍 방식으로 설정하려고합니다. 이 기사에서 매우 유사한 설명 : http://tomee.apache.org/functional-testing-with-openejb,-jetty-and-selenium.html.
이 설정은 IDE 또는 Maven에서 셀레늄 테스트를 시작하고 동일한 코드를 사용하여 개발 용 서버를 시작할 수 있기 때문에 매우 좋습니다.
이 설정은 이전 버전의 Jetty (6.2)와 EJB 3.0에서 알 수없는 EJB 컨테이너 (MyContainer라고 함)를 사용하여 작동하는 것을 보았습니다. 이제 Wildfly 10.1.0에서 실행되고 CDI (BeanManager)에 의한 EJB 조회를 수행하는 새로운 프로젝트에서 동일한 작업을 수행하고 있습니다 (또는 시도 중입니다 ...).
그러나 Jetty 및 OpenEJB 또는 TomEE의 최신 버전에서 CDI가 올바르게 작동하도록하는 데 몇 가지 문제가 있습니다. 새로운 버전의 프레임 워크를 사용하면 인터넷에서 다른 예를 찾을 수 없습니다. 그렇게하기 위해 정말로 Jetty가 필요한지조차 모르겠습니다.
첫 번째 시도 : Jetty (jetty-jndi 없음) + OpenEJB + tomee.jpa.cdi = false
OpenEJB 4.7.4 및 Jetty 9.4를 사용하여 CDI.current (). getBeanManager () 코드를 실행하면 다음과 같은 결과가 나타납니다.
java.lang.IllegalStateException : CDI에 액세스 할 수 없습니다.
persistence.xml :

Obs .: beans.xml 파일은 모든 시도에서 내 webapp의 WEB-INF 디렉토리에 있습니다.
두 번째 시도 : Jetty (jetty-jndi 없음) + TomEE + tomee.jpa.cdi = false
TomEE 7.0.3 및 Jetty 9.4를 사용하면 CDI가 Maven 종속성에서 TomEE에 대한 OpenEJB 만 변경할 수 있습니다 (이상합니다! OpenEJB가 CDI를 지원한다고 가정합니다). 이 CDI는 서버 설정 중간에 디버깅 할 때 작동하지만 프로그램이 webapp에 도달하면 EJB 조회를 만들려고 할 때 오류가 발생합니다.
"초기화 된 컨텍스트가없는 스레드 또는 배포 된 앱을 매핑하는 클래스 로더"
세 번째 시도 : Jetty (jetty-jndi 사용) + TomEE 또는 OpenEJB + tomee.jpa.cdi = false
EJB 컨테이너가 시작되지만 java : comp / env /를 찾을 수 없기 때문에 Jetty 서버를 시작할 수 없습니다.
javax.naming.NameNotFoundException : "comp / env"이름을 찾을 수 없습니다.
코드 추가 :
Configuration.ClassList classlist = Configuration.ClassList.setServerDefault (서버);
classlist.addAfter ( "org.eclipse.jetty.webapp.FragmentConfiguration",
"org.eclipse.jetty.plus.webapp.EnvConfiguration",
"org.eclipse.jetty.plus.webapp.PlusConfiguration");
네 번째 시도 : Jetty (jetty-jndi 없음) + TomEE + tomee.jpa.factory.lazy = true
persistence.xml에서 특성을 변경하십시오.

EJB 컨테이너가 시작되고 CDI.current ()가 존재하지만 그 후에 코드로 SQL을 실행하려고하면 :
@PersistenceContext (unitName = "my-pu")
개인 EntityManager em;
//방법
세션 세션 = em.unwrap (Session.class);
session.doWork (new Work () {
@우세하다
public void execute (Connection connection) throws SQLException {
try (명령문 = connection.createStatement ()) {
statement.executeUpdate (sql);
connection.commit ();
}
}
});
시스템이 Session session = em.unwrap (Session.class);에서 많은 시간을 멈 춥니 다. 그 후 많은 오류가 나타납니다 (Hibernate SessionFactory를 빌드 할 수 없음, org.hibernate.persister.entity.SingleTableEntityPersister에 대한 생성자를 가져올 수 없음) 및 스택 트레이스 끝에 :
원인 : javax.ejb.ConcurrentAccessTimeoutException : Stateless Session Bean 풀에서 사용 가능한 인스턴스가 없습니다. 30 초 기다림
질문
그래서, 클래스 경로 문제가 될 수 있습니까? 이전 EJB 컨테이너에서 일부 종속성을 제거한 후에 해결 된 TomEE CDI에 이미 몇 가지 문제가있었습니다. 나는 원인이 cdi-api 종속성과 관련된 잘못된 가져 오기라는 CDI 문제에 대해 이미 읽었습니다.
누군가가 이런 종류의 환경을 작동시키기 위해 저와 매우 다른 (그리고 더 단순한) 아이디어를 가지고 있다면, 그것도 환영합니다.
코드의 일부 관련 부분
Maven 종속성 JavaEE API :
<종속성>
 javax 
 javaee-api 
<버전> 7.0 
 제공됨 

Maven 종속성 CDI API :
<종속성>
 javax.enterprise 
 cdi-api 
<버전> 1.2 
 제공됨 

Maven 종속성 OpenEJB 4.7.4 :
<종속성>
 org.apache.openejb 
 openejb 코어 
<버전> 4.7.4 

Maven 종속성 TomEE 7.0.3 :
<종속성>
 org.apache.tomee 
 openejb 코어 
<버전> 7.0.3 

Maven 종속성둑:
<종속성>
 org.eclipse.jetty 
 제티 서버 
<버전> 9.4.6.v20170531 

<종속성>
 org.eclipse.jetty 
 제티 웹앱 
<버전> 9.4.6.v20170531 

<종속성>
 org.eclipse.jetty 
 제티 플러스 
<버전> 9.4.6.v20170531 

<종속성>
 org.eclipse.jetty 
 제티 -jndi 
<버전> 9.4.6.v20170531 

persistence.xml

->

ServiceLocator 조회 코드 (ServiceLocator.lookup (CrudService.class)) :
@우세하다
public Object lookup (Class  type, Annotation ... annotations) throws NamingException {
BeanManager 관리자 = CDI.current (). getBeanManager ();
Iterator > beans = manager.getBeans (type, annotations) .iterator ();
if (! beans.hasNext ()) {
throw new NamingException ( "CDI BeanManager는 요청 된 유형의 인스턴스를 찾을 수 없습니다"+ type.getName ());
}
Bean  bean = beans.next ();
CreationalContext  ctx = manager.createCreationalContext (bean);
return manager.getReference (bean, type, ctx);
}
EJBContainer 만들기 :
EJBContainer.createEJBContainer (props) .getContext (); // 소품에 특별한 것은 없습니다. 
org.apache.tomee javaee api 만 사용하고 javax spec jar를 먼저 사용하지 마십시오.
그런 다음 jetty jndi 설치 프로그램이 기존 설정을 단독으로 가정하여 중단하기 때문에 jndi 시스템 속성 (슬프게도 런타임에)을 강제로 실행하여 openejb 패키지를 먼저 설정할 수 있습니다.
또한 로그 또는 프로젝트를 공유 할 수 있으며 어떤 일이 발생하는지 아는 데 도움이 될 수 있습니다.
|
너의 답
StackExchange.ifUsing ( "editor", function () {
StackExchange.using ( "externalEditor", function () {
StackExchange.using ( "snippets", function () {
StackExchange.snippets.init ();
});
});
}, "코드 스 니펫");
StackExchange.ready (function () {
var channelOptions = {
태그 : "".split ( ""),
id : "1"
};
initTagRenderer ( "". split ( ""), "".split ( ""), channelOptions);
StackExchange.using ( "externalEditor", function () {
// 스 니펫이 활성화 된 경우 스 니펫 후에 편집기를 실행해야합니다.
if (StackExchange.settings.snippets.snippetsEnabled) {
StackExchange.using ( "snippets", function () {
createEditor ();
});
}
else {
createEditor ();
}
});
function createEditor () {
StackExchange.prepareEditor ({
useStacksEditor : false,
heartbeatType : '답변',
autoActivateHeartbeat : false,
convertImagesToLinks : true,
noModals : true,
showLowRepImageUploadWarning : true,
scoreToPostImages : 10,
bindNavPrevention : true,
접미사 : "",
imageUploader : {
brandingHtml : "Powered by \ u003ca href = \"https : //imgur.com/ \ "\ u003e \ u003csvg class = \"svg-icon \ "width = \"50 \ "height = \"18 \ "viewBox = \ "0 0 50 18 \"fill = \ "none \"xmlns = \ "http : //www.w3.org/2000/svg \"\ u003e \ u003cpath d = \ "M46.1709 9.17788C46.1709 8.26454 46.2665 7.94324 47.1084 7.58816C47.4091 7.46349 47.7169 7.36433 48.0099 7.26993C48.9099 6.97997 49.672 6.73443 49.672 5.93063C49.672 5.22043 48.9832 4.61182 48.1414 4.6931182C47.4335 4.61182 46.7256 4.52513.6307884.65959531 43.5251. 43.1481 6.59048V11.9512C43.1481 13.2535 43.6264 13.8962 44.6595 13.8962C45.6924 13.8962 46.1709 13.2535 46.1709 11.9512V9.17788Z \ "/ \ u003e \ u003cpath d = \"M32.492 10.1419C32.492 12.697954 34.104182 14.0484 37.0451 14.0484 41.5985 12.6954 41.5985 10.1419V6.59049C41.5985 5.28821 41.1394 4.66232 40.1061 4.66232C39.0732 4.66232 38.5948 5.28821 38.5948 6.59049V9.60062C38.5948 10.8521 38.2696 11.5455 37.0451 11.5455C35.8209 11.5455 35.4954 10.8 521 35.4954 9.60062V6.59049C35.4954 5.28821 35.0173 4.66232 34.0034 4.66232C32.9703 4.66232 32.492 5.28821 32.492 6.59049V10.1419Z \ "/ \ u003e \ u003cpath fill-rule = \"evenodd \ "clip-rule = \"evenodd \ "d = \ "M25.6622 17.6335C27.8049 17.6335 29.3739 16.9402 30.2537 15.6379C30.8468 14.7755 30.9615 13.5579 30.9615 11.9512V6.59049C30.9615 5.28821 30.4833 4.66231 29.4502 4.66231C28.9913 4.66231 4.66231C28.9913 4.66231 285.733.4555 4.9456087 28.1109 5.50756087 .1369 4.56087 21.0134 6.57349 21.0134 9.27932C21.0134 11.9852 23.003 13.913 25.3754 13.913C26.5612 13.913 27.4607 13.4902 28.1109 12.6616C28.1109 12.7229 28.1161 12.7799 28.121 12.8346C28.1256 12.8854 28.1301 12.9839342 15.1301 25. 15.2321 24.1352 14.9821 23.5661 14.7787C23.176 14.6393 22.8472 14.5218 22.5437 14.5218C21.7977 14.5218 21.2429 15.0123 21.2429 15.6887C21.2429 16.7375 22.9072 17.6335 25.6622 17.628335ZM24.1317 9.27932C24.1317 7.94324 7.0932C24.1317 7.94324 27.2119 7.09766 28.0918 7.94324 28.0918 9.27932C28.0918 10.6321 27.2311 11.5116 26.1024 11.5116C24.9737 11.5116 24.1317 10.6491 24.1317 9.27932Z \ "/ \ u003e \ u003cpath d = \"M16.809.345 11.9512C16.8045 13.8962 17.2637 13.8962 13.2962 17.2637 13.8962 19.8079 13.2535 19.8079 11.9512V8.12928C19.8079 5.82936 18.4879 4.62866 16.4027 4.62866C15.1594 4.62866 14.279 4.98375 13.3609 5.88013C12.653 5.05154 11.6581 4.62866 10.3573 4.62866C9.34336 4.62866 7.78506C9.34336 4.62866 8.510506 5.00066 5.28821 5.00066 6.59049V11.9512C5.00066 13.2535 5.47873 13.8962 6.51203 13.8962C7.54479 13.8962 8.0232 13.2535 8.0232 11.9512V8.90741C8.0232 7.58817 8.44431 6.91179 9.53458 6.91179C10.5104 6.91179 10.893 7.58817 10.893 8.94108V11.4049512C10.893 13.2. C13.4375 13.8962 13.9157 13.2535 13.9157 11.9512V8.90741C13.9157 7.58817 14.3365 6.91179 15.4269 6.91179C16.4027 6.91179 16.8045 7.58817 16.8045 8.94108V11.9512Z \ "/ \ u003e \ u003cpath d = \ "M3.31675 6.59049C3.31675 5.28821 2.83866 4.66232 1.82471 4.66232C0.791758 4.66232 0.313354 5.28821 0.313354 6.59049V11.9512C0.313354 13.2535 0.791758 13.8962 1.82471 13.8962C2.85798 13.8962 3.31675 13.2535 3.31675 11.9512V6.59049Z u003e \ u003cpath d = \ "M1.87209 0.400291C0.843612 0.400291 0 1.1159 0 1.98861C0 2.87869 0.822846 3.57676 1.87209 3.57676C2.90056 3.57676 3.7234 2.87869 3.7234 1.98861C3.7234 1.1159 2.90056 0.400291 1.87209 0.400291Z \"fill = \ "# 1BB76E \ "/ \ u003e \ u003c / svg \ u003e \ u003c / a \ u003e",
contentPolicyHtml : "\ u003ca href = \"https : //stackoverflow.com/help/licensing \ "\ u003ecc에 따라 라이선스가 부여 된 사용자 기여by-sa \ u003c / a \ u003e \ u003ca href = \ "https : //stackoverflow.com/legal/content-policy \"\ u003e (콘텐츠 정책) \ u003c / a \ u003e ",
allowUrls : true
},
onDemand : true,
폐기 선택기 : ".discard-answer"
, immediatelyShowMarkdownHelp : true, enableTables : true, enableSnippets : true
});
}
});
Stack Overflow에 대한 답변에 기여해 주셔서 감사합니다!
질문에 반드시 답해주십시오. 세부 사항을 제공하고 연구를 공유하십시오!
그러나 피하십시오…
도움, 설명을 요청하거나 다른 답변에 응답합니다.
의견에 근거한 진술 작성 참고 자료 또는 개인적인 경험으로 백업하십시오.
자세한 내용은 훌륭한 답변 작성에 대한 팁을 참조하십시오.
초안 저장
초안이 삭제되었습니다.
가입 또는 로그인
StackExchange.ready (function () {
StackExchange.helpers.onClickDraftSave ( '# login-link');
});
Google을 사용하여 가입
Facebook을 사용하여 가입
이메일 및 비밀번호를 사용하여 가입
제출
게스트로 게시
이름
이메일
필수이지만 표시되지 않음
StackExchange.ready (
함수 () {
StackExchange.openid.initPostLogin ( '. new-post-login', 'https % 3a % 2f % 2fstackoverflow.com % 2fquestions % 2f45538143 % 2fproblems-with-cdi-in-setup-for-functional-testing-with-tomee- or-openejb-jetty % 23new-answer ','question_page ');
}
);
게스트로 게시
이름
이메일
필수이지만 표시되지 않음
답변 게시
포기
"답변 게시"를 클릭하면 서비스 약관, 개인 정보 보호 정책 및 쿠키 정책에 동의하게됩니다.
찾고있는 답변이 아닙니까? ejb jetty cdi apache-tomee openejb 태그가 지정된 다른 질문을 찾아 보거나 직접 질문하십시오.